/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package br.edu.unifei.portal.dao;

import br.edu.unifei.portal.modelo.Departamento;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.Query;

/**
 *
 * @author Douglas Soares
 */
public class DepartamentoDao {

    private EntityManager em;

    public DepartamentoDao(EntityManager em) {
        this.em = em;
    }

    public void create(Departamento departamento) {
        em.getTransaction().begin();
        em.persist(departamento);
        em.getTransaction().commit();
    }

    public void update(Departamento departamento) {
        em.getTransaction().begin();
        em.merge(departamento);
        em.getTransaction().commit();
    }

    public void delete(String sigla) {
        em.getTransaction().begin();
        Departamento c = findDepartamento(sigla);
        em.remove(c);
        em.getTransaction().commit();
    }

    public Departamento findDepartamento(String sigla) {
        return (Departamento) em.createQuery(
                "from Departamento where sigla = '" + sigla + "'").getSingleResult();
    }

    public List<Departamento> findAllDepartamento() {
        return em.createQuery("from Departamento").getResultList();
    }

    public List<Departamento> findPageDepartamento(int max, int first) {
        Query query = em.createQuery("from Departamento");
        query.setMaxResults(max);
        query.setFirstResult(first);
        return query.getResultList();
    }

    public long getCountDepartamento() {
        Query query = em.createQuery("from Departamento");
        return (Long) em.createQuery(
                "select count(*) from Departamento").getSingleResult();
    }
}
